草庐IT

C++11 auto 和 size_type

全部标签

c++ - 为什么 std::allocator<>::deallocate() 有一个未使用的 size_type 参数?

使用std::allocator时,deallocate函数需要pointer参数,和一个size_type参数(std::allocator::deallocate(std::allocator::pointerp,std::allocator::size_type)。但是,没有使用size_type,也不是可选的。那么为什么它在那里?这让我很困惑,因为它应该是可选的,甚至不在那里,因为它没有在函数中使用.编辑:MSVC的分配器实现deallocatevoiddeallocate(pointer_Ptr,size_type){//deallocateobjectat_Ptr,igno

c++ - const 引用是错误的 C++ 11

我在YouTube上观看BjarneStroustrup,我试图弄清楚为什么这被认为是糟糕的,因为他说这是C++98风格的糟糕代码voidsetInt(constunsignedint&i)voidtakeaString(conststd::string&str)我的意思是你正在传递一个对常量的引用,这样你就可以省去复制操作,而且它甚至不像传递指针那样使用,所以它不必取消引用,所以为什么不好? 最佳答案 在C++11之前的版本中,一般的经验法则是如果您不修改参数,则按值传递内置类型,并按const&传递类或结构的对象,因为类或结构的

C++1y/C++14 : Converting static constexpr array to non-type template parameter pack?

假设我有一个静态存储持续时间的constexpr数组(已知范围):constexprTinput[]=/*...*/;我有一个需要打包的输出类模板:templatestructoutput_template;我想像这样实例化output_template:usingoutput=output_template;一种方法是:templatestructmake_output_template{templatestaticconstexproutput_templatef(std::index_sequence){return{};};usingtype=decltype(f(std::m

c++ - 错误 : invalid operands of types 'int' and '<unresolved overloaded function type>' to binary 'operator<<'

我想获取z_Data的第48个字符的第6位{charc=pPkt->z_Data[47];//thisz_Dataisacharbufferstd::cout>3)&1>4)&1>5)&1 最佳答案 优先级高于&,所以你需要:std::cout>3)&1)>4)&1)>5)&1) 关于c++-错误:invalidoperandsoftypes'int'and''tobinary'operator https://stackoverflow.com/questions/246

C++11:赋值运算符是否会阻止类型被 POD,从而被全局初始化?

背景:我在一个大型代码环境中,其中运行全局构造函数的未定义顺序存在问题。所以我有一个自定义类,旨在延迟初始化直到首次使用。它所有的魔力都发生在它的operator*和operator->函数中;它们是唯一定义的东西。它还在自身内部存储一些状态,以供自动初始化功能使用。当然,那个状态必须是POD,这样整个类都是POD,这样它就可以在任何人的代码开始运行之前就完全设置好,这样所有的代码都可以在任何地方使用所有的全局变量,而不用担心全局变量没有'尚未设置。前段时间有人添加了一个私有(private)的、从未定义的赋值运算符,这样该类型就永远不会被分配给(无论如何它都不会被设计成永远改变)。现

c++ - 为什么 C++11 没有模板类型定义?

为什么C++11没有“模板类型定义”,比如templatetypedefstd::vector>vec;相反,他们只允许新语法:templateusingvec=std::vector>; 最佳答案 n1406是HerbSutter提出的“typedef模板”的提议,它模仿了您问题中的语法。n1499建议“模板别名”取代它,其中包含using当前存在于C++11中的语法。“typedef模板”的主要缺点之一在这两篇论文中都得到了解决。来自n1406:Inexistingpractice,includinginthestandardl

Hibernate:即使我在配置文件中设置了batch_size,为什么还要手动flush()?

我正在学习使用Java的Hibernate5.2.10。我从网上的一些教程开始,但面临以下问题。使用批处理时,我看到的所有教程首先设置hibernate.jdbc.batch_size在配置文件中。之后,代码与此相似:Sessionsession=SessionFactory.openSession();Transactiontx=session.beginTransaction();for(inti=0;i我为什么要做flush()和clear()手动?这不是应该通过冬眠自动完成的事情,因为我已经设置了hibernate.jdbc.batch_size在配置文件中?对我来说,似乎我正在手动进

c++ - QMetaType::Float 不在 QVariant::Type 中

我有一个运行良好的应用程序,但它不是在打开警告的情况下编译的。我正在尝试将其重新打开并整理它们,但没有关于如何解决此问题的想法。我有:QVariantsomeVarQVariant::TypevariantType=someVar.type();switch(variantType){caseQMetaType::QString:doSomething1();break;caseQMetaType::Float:doSomething2();break;}并收到此警告/错误:error:casevalue‘135’notinenumeratedtype‘QVariant::Type’[

c++11 std::hash 函数对象类线程安全

在c++11中是在中声明的散列函数类对象线程安全?例如,从多个线程调用此函数是否安全?size_thash1(conststd::string&s){std::hashstr_hash;returnstr_hash(s);}或者,如果有一个全局对象std::hashstr_hash_global;,那么从多个线程调用第二个函数是否安全?size_thash2(conststd::string&s){returnstr_hash_global(s);} 最佳答案 标准库promise,如果您只在标准库对象上调用const限定的成员函数

C++11 线程卡在锁定互斥锁上

使用C++11std::thread、std::mutex,我正在编写一个简单的工作线程。但是,我在锁定std::mutex时遇到了一个奇怪的挂起问题,看起来两个线程(主线程和工作线程)都试图锁定互斥锁,但都被阻止了。完整代码#include#include#include#include#includestd::condition_variablecv;std::mutexm;std::threadt;boolshouldExit=false;std::listjobs;voidthread_func(){std::unique_locklock(m);while(!shouldEx